<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>3.11.jQuery常用API-jQuery尺寸-scrollTop()+练习：带有动画返回顶部</title>
    <style>
        body {
            height: 2000px;
        }

        .back {
            position: fixed;
            width: 50px;
            height: 50px;
            background-color: pink;
            right: 30px;
            bottom: 100px;
            display: none;
            cursor: pointer;
        }

        .container {
            width: 900px;
            height: 500px;
            background-color: skyblue;
            margin: 400px auto;
        }
    </style>
    <script src="jquery.min.js"></script>
</head>

<body>
    <div class="back">返回顶部</div>
    <div class="container">
    </div>
    <script>
        $(function () {
            // 设置页面一打开就卷去100像素
            $(document).scrollTop(100);
            // 被卷去的头部 scrollTop()  / 被卷去的左侧 scrollLeft()
            // 页面滚动事件
            var boxTop = $(".container").offset().top;
            $(window).scroll(function () {
                console.log($(document).scrollTop());
                if ($(document).scrollTop() >= boxTop) {
                    $(".back").fadeIn();
                } else {
                    $(".back").fadeOut();
                };
            });
            // 带有动画的返回顶部
            // 1.核心原理：使用animate动画返回顶部
            // 2.animate动画函数里面有个scrollTop属性，可以设置位置
            // 3.但是 是元素做动画，因此$("body,html").animate({scrollTop(0)})
            $(".back").click(function () {
                $("body,html").stop().animate({
                    scrollTop: 0
                });
                // $("document").stop().animate({
                //     scrollTop: 0
                // }); 不能是文档，而是html和body元素做动画
            });
        })
    </script>
</body>

</html>